﻿#region Using directives

using System;
using System.Data;
using System.Data.Common;
using System.Collections;
using System.Collections.Generic;

using NguyenHoa.Domains;
using NguyenHoa.Data;

#endregion

namespace NguyenHoa.Data.Bases
{	
	///<summary>
	/// This class is the base class for any <see cref="MultimediaProviderBase"/> implementation.
	/// It exposes CRUD methods as well as selecting on index, foreign keys and custom stored procedures.
	///</summary>
	public abstract partial class MultimediaProviderBaseCore : EntityProviderBase<NguyenHoa.Domains.Multimedia, NguyenHoa.Domains.MultimediaKey>
	{		
		#region Get from Many To Many Relationship Functions
		#endregion	
		
		#region Delete Methods

		/// <summary>
		/// 	Deletes a row from the DataSource.
		/// </summary>
		/// <param name="transactionManager">A <see cref="TransactionManager"/> object.</param>
		/// <param name="key">The unique identifier of the row to delete.</param>
		/// <returns>Returns true if operation suceeded.</returns>
		public override bool Delete(TransactionManager transactionManager, NguyenHoa.Domains.MultimediaKey key)
		{
			return Delete(transactionManager, key.Id);
		}
		
		/// <summary>
		/// 	Deletes a row from the DataSource.
		/// </summary>
		/// <param name="_id">. Primary Key.</param>
		/// <remarks>Deletes based on primary key(s).</remarks>
		/// <returns>Returns true if operation suceeded.</returns>
		public bool Delete(System.Int32 _id)
		{
			return Delete(null, _id);
		}
		
		/// <summary>
		/// 	Deletes a row from the DataSource.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_id">. Primary Key.</param>
		/// <remarks>Deletes based on primary key(s).</remarks>
		/// <returns>Returns true if operation suceeded.</returns>
		public abstract bool Delete(TransactionManager transactionManager, System.Int32 _id);		
		
		#endregion Delete Methods
		
		#region Get By Foreign Key Functions
	
		/// <summary>
		/// 	Gets rows from the datasource based on the FK_tblMultimedia_tblAlbum key.
		///		FK_tblMultimedia_tblAlbum Description: 
		/// </summary>
		/// <param name="_albumId"></param>
		/// <returns>Returns a typed collection of NguyenHoa.Domains.Multimedia objects.</returns>
		public TList<Multimedia> GetByAlbumId(System.Int32? _albumId)
		{
			int count = -1;
			return GetByAlbumId(_albumId, 0,int.MaxValue, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the FK_tblMultimedia_tblAlbum key.
		///		FK_tblMultimedia_tblAlbum Description: 
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_albumId"></param>
		/// <returns>Returns a typed collection of NguyenHoa.Domains.Multimedia objects.</returns>
		/// <remarks></remarks>
		public TList<Multimedia> GetByAlbumId(TransactionManager transactionManager, System.Int32? _albumId)
		{
			int count = -1;
			return GetByAlbumId(transactionManager, _albumId, 0, int.MaxValue, out count);
		}
		
			/// <summary>
		/// 	Gets rows from the datasource based on the FK_tblMultimedia_tblAlbum key.
		///		FK_tblMultimedia_tblAlbum Description: 
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_albumId"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		///  <param name="pageLength">Number of rows to return.</param>
		/// <remarks></remarks>
		/// <returns>Returns a typed collection of NguyenHoa.Domains.Multimedia objects.</returns>
		public TList<Multimedia> GetByAlbumId(TransactionManager transactionManager, System.Int32? _albumId, int start, int pageLength)
		{
			int count = -1;
			return GetByAlbumId(transactionManager, _albumId, start, pageLength, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the FK_tblMultimedia_tblAlbum key.
		///		fkTblMultimediaTblAlbum Description: 
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="_albumId"></param>
		/// <remarks></remarks>
		/// <returns>Returns a typed collection of NguyenHoa.Domains.Multimedia objects.</returns>
		public TList<Multimedia> GetByAlbumId(System.Int32? _albumId, int start, int pageLength)
		{
			int count =  -1;
			return GetByAlbumId(null, _albumId, start, pageLength,out count);	
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the FK_tblMultimedia_tblAlbum key.
		///		fkTblMultimediaTblAlbum Description: 
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="_albumId"></param>
		/// <param name="count">out parameter to get total records for query</param>
		/// <remarks></remarks>
		/// <returns>Returns a typed collection of NguyenHoa.Domains.Multimedia objects.</returns>
		public TList<Multimedia> GetByAlbumId(System.Int32? _albumId, int start, int pageLength,out int count)
		{
			return GetByAlbumId(null, _albumId, start, pageLength, out count);	
		}
						
		/// <summary>
		/// 	Gets rows from the datasource based on the FK_tblMultimedia_tblAlbum key.
		///		FK_tblMultimedia_tblAlbum Description: 
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_albumId"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">The total number of records.</param>
		/// <returns>Returns a typed collection of NguyenHoa.Domains.Multimedia objects.</returns>
		public abstract TList<Multimedia> GetByAlbumId(TransactionManager transactionManager, System.Int32? _albumId, int start, int pageLength, out int count);
		
		#endregion

		#region Get By Index Functions
		
		/// <summary>
		/// 	Gets a row from the DataSource based on its primary key.
		/// </summary>
		/// <param name="transactionManager">A <see cref="TransactionManager"/> object.</param>
		/// <param name="key">The unique identifier of the row to retrieve.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <returns>Returns an instance of the Entity class.</returns>
		public override NguyenHoa.Domains.Multimedia Get(TransactionManager transactionManager, NguyenHoa.Domains.MultimediaKey key, int start, int pageLength)
		{
			return GetById(transactionManager, key.Id, start, pageLength);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the primary key PK_tblMultimedia index.
		/// </summary>
		/// <param name="_id"></param>
		/// <returns>Returns an instance of the <see cref="NguyenHoa.Domains.Multimedia"/> class.</returns>
		public NguyenHoa.Domains.Multimedia GetById(System.Int32 _id)
		{
			int count = -1;
			return GetById(null,_id, 0, int.MaxValue, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tblMultimedia index.
		/// </summary>
		/// <param name="_id"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="NguyenHoa.Domains.Multimedia"/> class.</returns>
		public NguyenHoa.Domains.Multimedia GetById(System.Int32 _id, int start, int pageLength)
		{
			int count = -1;
			return GetById(null, _id, start, pageLength, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tblMultimedia index.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_id"></param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="NguyenHoa.Domains.Multimedia"/> class.</returns>
		public NguyenHoa.Domains.Multimedia GetById(TransactionManager transactionManager, System.Int32 _id)
		{
			int count = -1;
			return GetById(transactionManager, _id, 0, int.MaxValue, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tblMultimedia index.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_id"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="NguyenHoa.Domains.Multimedia"/> class.</returns>
		public NguyenHoa.Domains.Multimedia GetById(TransactionManager transactionManager, System.Int32 _id, int start, int pageLength)
		{
			int count = -1;
			return GetById(transactionManager, _id, start, pageLength, out count);
		}
		
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tblMultimedia index.
		/// </summary>
		/// <param name="_id"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">out parameter to get total records for query</param>
		/// <remarks></remarks>
		/// <returns>Returns an instance of the <see cref="NguyenHoa.Domains.Multimedia"/> class.</returns>
		public NguyenHoa.Domains.Multimedia GetById(System.Int32 _id, int start, int pageLength, out int count)
		{
			return GetById(null, _id, start, pageLength, out count);
		}
		
				
		/// <summary>
		/// 	Gets rows from the datasource based on the PK_tblMultimedia index.
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="_id"></param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="count">The total number of records.</param>
		/// <returns>Returns an instance of the <see cref="NguyenHoa.Domains.Multimedia"/> class.</returns>
		public abstract NguyenHoa.Domains.Multimedia GetById(TransactionManager transactionManager, System.Int32 _id, int start, int pageLength, out int count);
						
		#endregion "Get By Index Functions"
	
		#region Custom Methods
		
		
		#region _tblMultimedia_DeleteByIdList 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_DeleteByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void DeleteByIdList(System.String idList)
		{
			 DeleteByIdList(null, 0, int.MaxValue , idList);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_DeleteByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void DeleteByIdList(int start, int pageLength, System.String idList)
		{
			 DeleteByIdList(null, start, pageLength , idList);
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_DeleteByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void DeleteByIdList(TransactionManager transactionManager, System.String idList)
		{
			 DeleteByIdList(transactionManager, 0, int.MaxValue , idList);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_DeleteByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public abstract void DeleteByIdList(TransactionManager transactionManager, int start, int pageLength , System.String idList);
		
		#endregion
		
		#region _tblMultimedia_GetVideoByStatus 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByStatus' stored procedure. 
		/// </summary>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetVideoByStatus(System.String status)
		{
			return GetVideoByStatus(null, 0, int.MaxValue , status);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByStatus' stored procedure. 
		/// </summary>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetVideoByStatus(int start, int pageLength, System.String status)
		{
			return GetVideoByStatus(null, start, pageLength , status);
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByStatus' stored procedure. 
		/// </summary>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetVideoByStatus(TransactionManager transactionManager, System.String status)
		{
			return GetVideoByStatus(transactionManager, 0, int.MaxValue , status);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByStatus' stored procedure. 
		/// </summary>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public abstract TList<Multimedia> GetVideoByStatus(TransactionManager transactionManager, int start, int pageLength , System.String status);
		
		#endregion
		
		#region _tblMultimedia_GetPhotoForHome 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoForHome' stored procedure. 
		/// </summary>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="DataSet"/> instance.</returns>
		public DataSet GetPhotoForHome()
		{
			return GetPhotoForHome(null, 0, int.MaxValue );
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoForHome' stored procedure. 
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="DataSet"/> instance.</returns>
		public DataSet GetPhotoForHome(int start, int pageLength)
		{
			return GetPhotoForHome(null, start, pageLength );
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoForHome' stored procedure. 
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="DataSet"/> instance.</returns>
		public DataSet GetPhotoForHome(TransactionManager transactionManager)
		{
			return GetPhotoForHome(transactionManager, 0, int.MaxValue );
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoForHome' stored procedure. 
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="DataSet"/> instance.</returns>
		public abstract DataSet GetPhotoForHome(TransactionManager transactionManager, int start, int pageLength );
		
		#endregion
		
		#region _tblMultimedia_GetPhotoByType 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoByType' stored procedure. 
		/// </summary>
		/// <param name="type"> A <c>System.String</c> instance.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetPhotoByType(System.String type)
		{
			return GetPhotoByType(null, 0, int.MaxValue , type);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoByType' stored procedure. 
		/// </summary>
		/// <param name="type"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetPhotoByType(int start, int pageLength, System.String type)
		{
			return GetPhotoByType(null, start, pageLength , type);
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoByType' stored procedure. 
		/// </summary>
		/// <param name="type"> A <c>System.String</c> instance.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetPhotoByType(TransactionManager transactionManager, System.String type)
		{
			return GetPhotoByType(transactionManager, 0, int.MaxValue , type);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetPhotoByType' stored procedure. 
		/// </summary>
		/// <param name="type"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public abstract TList<Multimedia> GetPhotoByType(TransactionManager transactionManager, int start, int pageLength , System.String type);
		
		#endregion
		
		#region _tblMultimedia_GetAllVideo 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetAllVideo' stored procedure. 
		/// </summary>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetAllVideo()
		{
			return GetAllVideo(null, 0, int.MaxValue );
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetAllVideo' stored procedure. 
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetAllVideo(int start, int pageLength)
		{
			return GetAllVideo(null, start, pageLength );
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetAllVideo' stored procedure. 
		/// </summary>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetAllVideo(TransactionManager transactionManager)
		{
			return GetAllVideo(transactionManager, 0, int.MaxValue );
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetAllVideo' stored procedure. 
		/// </summary>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public abstract TList<Multimedia> GetAllVideo(TransactionManager transactionManager, int start, int pageLength );
		
		#endregion
		
		#region _tblMultimedia_SetVideoOnHome 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_SetVideoOnHome' stored procedure. 
		/// </summary>
		/// <param name="id"> A <c>System.Int32?</c> instance.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void SetVideoOnHome(System.Int32? id)
		{
			 SetVideoOnHome(null, 0, int.MaxValue , id);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_SetVideoOnHome' stored procedure. 
		/// </summary>
		/// <param name="id"> A <c>System.Int32?</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void SetVideoOnHome(int start, int pageLength, System.Int32? id)
		{
			 SetVideoOnHome(null, start, pageLength , id);
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_SetVideoOnHome' stored procedure. 
		/// </summary>
		/// <param name="id"> A <c>System.Int32?</c> instance.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void SetVideoOnHome(TransactionManager transactionManager, System.Int32? id)
		{
			 SetVideoOnHome(transactionManager, 0, int.MaxValue , id);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_SetVideoOnHome' stored procedure. 
		/// </summary>
		/// <param name="id"> A <c>System.Int32?</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public abstract void SetVideoOnHome(TransactionManager transactionManager, int start, int pageLength , System.Int32? id);
		
		#endregion
		
		#region _tblMultimedia_SaveStatusByIdList 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_SaveStatusByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void SaveStatusByIdList(System.String idList, System.String status)
		{
			 SaveStatusByIdList(null, 0, int.MaxValue , idList, status);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_SaveStatusByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void SaveStatusByIdList(int start, int pageLength, System.String idList, System.String status)
		{
			 SaveStatusByIdList(null, start, pageLength , idList, status);
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_SaveStatusByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public void SaveStatusByIdList(TransactionManager transactionManager, System.String idList, System.String status)
		{
			 SaveStatusByIdList(transactionManager, 0, int.MaxValue , idList, status);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_SaveStatusByIdList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="status"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		public abstract void SaveStatusByIdList(TransactionManager transactionManager, int start, int pageLength , System.String idList, System.String status);
		
		#endregion
		
		#region _tblMultimedia_GetVideoByList 
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetVideoByList(System.String idList)
		{
			return GetVideoByList(null, 0, int.MaxValue , idList);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetVideoByList(int start, int pageLength, System.String idList)
		{
			return GetVideoByList(null, start, pageLength , idList);
		}
				
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public TList<Multimedia> GetVideoByList(TransactionManager transactionManager, System.String idList)
		{
			return GetVideoByList(transactionManager, 0, int.MaxValue , idList);
		}
		
		/// <summary>
		///	This method wrap the '_tblMultimedia_GetVideoByList' stored procedure. 
		/// </summary>
		/// <param name="idList"> A <c>System.String</c> instance.</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">Number of rows to return.</param>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <remark>This method is generate from a stored procedure.</remark>
		/// <returns>A <see cref="TList&lt;Multimedia&gt;"/> instance.</returns>
		public abstract TList<Multimedia> GetVideoByList(TransactionManager transactionManager, int start, int pageLength , System.String idList);
		
		#endregion
		
		#endregion

		#region Helper Functions	
		
		/// <summary>
		/// Fill a TList&lt;Multimedia&gt; From a DataReader.
		/// </summary>
		/// <param name="reader">Datareader</param>
		/// <param name="rows">The collection to fill</param>
		/// <param name="start">Row number at which to start reading, the first row is 0.</param>
		/// <param name="pageLength">number of rows.</param>
		/// <returns>a <see cref="TList&lt;Multimedia&gt;"/></returns>
		public static TList<Multimedia> Fill(IDataReader reader, TList<Multimedia> rows, int start, int pageLength)
		{
			NetTiersProvider currentProvider = DataRepository.Provider;
            bool useEntityFactory = currentProvider.UseEntityFactory;
            bool enableEntityTracking = currentProvider.EnableEntityTracking;
            LoadPolicy currentLoadPolicy = currentProvider.CurrentLoadPolicy;
			Type entityCreationFactoryType = currentProvider.EntityCreationalFactoryType;
			
			// advance to the starting row
			for (int i = 0; i < start; i++)
			{
				if (!reader.Read())
				return rows; // not enough rows, just return
			}
			for (int i = 0; i < pageLength; i++)
			{
				if (!reader.Read())
					break; // we are done
					
				string key = null;
				
				NguyenHoa.Domains.Multimedia c = null;
				if (useEntityFactory)
				{
					key = new System.Text.StringBuilder("Multimedia")
					.Append("|").Append((System.Int32)reader[((int)MultimediaColumn.Id - 1)]).ToString();
					c = EntityManager.LocateOrCreate<Multimedia>(
					key.ToString(), // EntityTrackingKey
					"Multimedia",  //Creational Type
					entityCreationFactoryType,  //Factory used to create entity
					enableEntityTracking); // Track this entity?
				}
				else
				{
					c = new NguyenHoa.Domains.Multimedia();
				}
				
				if (!enableEntityTracking ||
					c.EntityState == EntityState.Added ||
					(enableEntityTracking &&
					
						(
							(currentLoadPolicy == LoadPolicy.PreserveChanges && c.EntityState == EntityState.Unchanged) ||
							(currentLoadPolicy == LoadPolicy.DiscardChanges && c.EntityState != EntityState.Unchanged)
						)
					))
				{
					c.SuppressEntityEvents = true;
					c.Id = (System.Int32)reader[((int)MultimediaColumn.Id - 1)];
					c.Name = (System.String)reader[((int)MultimediaColumn.Name - 1)];
					c.Path = (reader.IsDBNull(((int)MultimediaColumn.Path - 1)))?null:(System.String)reader[((int)MultimediaColumn.Path - 1)];
					c.AlbumId = (reader.IsDBNull(((int)MultimediaColumn.AlbumId - 1)))?null:(System.Int32?)reader[((int)MultimediaColumn.AlbumId - 1)];
					c.Status = (reader.IsDBNull(((int)MultimediaColumn.Status - 1)))?null:(System.String)reader[((int)MultimediaColumn.Status - 1)];
					c.PostedDate = (reader.IsDBNull(((int)MultimediaColumn.PostedDate - 1)))?null:(System.DateTime?)reader[((int)MultimediaColumn.PostedDate - 1)];
					c.PostedBy = (reader.IsDBNull(((int)MultimediaColumn.PostedBy - 1)))?null:(System.String)reader[((int)MultimediaColumn.PostedBy - 1)];
					c.Type = (reader.IsDBNull(((int)MultimediaColumn.Type - 1)))?null:(System.String)reader[((int)MultimediaColumn.Type - 1)];
					c.EntityTrackingKey = key;
					c.AcceptChanges();
					c.SuppressEntityEvents = false;
				}
				rows.Add(c);
			}
		return rows;
		}		
		/// <summary>
		/// Refreshes the <see cref="NguyenHoa.Domains.Multimedia"/> object from the <see cref="IDataReader"/>.
		/// </summary>
		/// <param name="reader">The <see cref="IDataReader"/> to read from.</param>
		/// <param name="entity">The <see cref="NguyenHoa.Domains.Multimedia"/> object to refresh.</param>
		public static void RefreshEntity(IDataReader reader, NguyenHoa.Domains.Multimedia entity)
		{
			if (!reader.Read()) return;
			
			entity.Id = (System.Int32)reader[((int)MultimediaColumn.Id - 1)];
			entity.Name = (System.String)reader[((int)MultimediaColumn.Name - 1)];
			entity.Path = (reader.IsDBNull(((int)MultimediaColumn.Path - 1)))?null:(System.String)reader[((int)MultimediaColumn.Path - 1)];
			entity.AlbumId = (reader.IsDBNull(((int)MultimediaColumn.AlbumId - 1)))?null:(System.Int32?)reader[((int)MultimediaColumn.AlbumId - 1)];
			entity.Status = (reader.IsDBNull(((int)MultimediaColumn.Status - 1)))?null:(System.String)reader[((int)MultimediaColumn.Status - 1)];
			entity.PostedDate = (reader.IsDBNull(((int)MultimediaColumn.PostedDate - 1)))?null:(System.DateTime?)reader[((int)MultimediaColumn.PostedDate - 1)];
			entity.PostedBy = (reader.IsDBNull(((int)MultimediaColumn.PostedBy - 1)))?null:(System.String)reader[((int)MultimediaColumn.PostedBy - 1)];
			entity.Type = (reader.IsDBNull(((int)MultimediaColumn.Type - 1)))?null:(System.String)reader[((int)MultimediaColumn.Type - 1)];
			entity.AcceptChanges();
		}
		
		/// <summary>
		/// Refreshes the <see cref="NguyenHoa.Domains.Multimedia"/> object from the <see cref="DataSet"/>.
		/// </summary>
		/// <param name="dataSet">The <see cref="DataSet"/> to read from.</param>
		/// <param name="entity">The <see cref="NguyenHoa.Domains.Multimedia"/> object.</param>
		public static void RefreshEntity(DataSet dataSet, NguyenHoa.Domains.Multimedia entity)
		{
			DataRow dataRow = dataSet.Tables[0].Rows[0];
			
			entity.Id = (System.Int32)dataRow["Id"];
			entity.Name = (System.String)dataRow["Name"];
			entity.Path = Convert.IsDBNull(dataRow["Path"]) ? null : (System.String)dataRow["Path"];
			entity.AlbumId = Convert.IsDBNull(dataRow["AlbumId"]) ? null : (System.Int32?)dataRow["AlbumId"];
			entity.Status = Convert.IsDBNull(dataRow["Status"]) ? null : (System.String)dataRow["Status"];
			entity.PostedDate = Convert.IsDBNull(dataRow["PostedDate"]) ? null : (System.DateTime?)dataRow["PostedDate"];
			entity.PostedBy = Convert.IsDBNull(dataRow["PostedBy"]) ? null : (System.String)dataRow["PostedBy"];
			entity.Type = Convert.IsDBNull(dataRow["Type"]) ? null : (System.String)dataRow["Type"];
			entity.AcceptChanges();
		}
		#endregion 
		
		#region DeepLoad Methods
		/// <summary>
		/// Deep Loads the <see cref="IEntity"/> object with criteria based of the child 
		/// property collections only N Levels Deep based on the <see cref="DeepLoadType"/>.
		/// </summary>
		/// <remarks>
		/// Use this method with caution as it is possible to DeepLoad with Recursion and traverse an entire object graph.
		/// </remarks>
		/// <param name="transactionManager"><see cref="TransactionManager"/> object</param>
		/// <param name="entity">The <see cref="NguyenHoa.Domains.Multimedia"/> object to load.</param>
		/// <param name="deep">Boolean. A flag that indicates whether to recursively save all Property Collection that are descendants of this instance. If True, saves the complete object graph below this object. If False, saves this object only. </param>
		/// <param name="deepLoadType">DeepLoadType Enumeration to Include/Exclude object property collections from Load.</param>
		/// <param name="childTypes">NguyenHoa.Domains.Multimedia Property Collection Type Array To Include or Exclude from Load</param>
		/// <param name="innerList">A collection of child types for easy access.</param>
	    /// <exception cref="ArgumentNullException">entity or childTypes is null.</exception>
	    /// <exception cref="ArgumentException">deepLoadType has invalid value.</exception>
		public override void DeepLoad(TransactionManager transactionManager, NguyenHoa.Domains.Multimedia entity, bool deep, DeepLoadType deepLoadType, System.Type[] childTypes, DeepSession innerList)
		{
			if(entity == null)
				return;

			#region AlbumIdSource	
			if (CanDeepLoad(entity, "Album|AlbumIdSource", deepLoadType, innerList) 
				&& entity.AlbumIdSource == null)
			{
				object[] pkItems = new object[1];
				pkItems[0] = (entity.AlbumId ?? (int)0);
				Album tmpEntity = EntityManager.LocateEntity<Album>(EntityLocator.ConstructKeyFromPkItems(typeof(Album), pkItems), DataRepository.Provider.EnableEntityTracking);
				if (tmpEntity != null)
					entity.AlbumIdSource = tmpEntity;
				else
					entity.AlbumIdSource = DataRepository.AlbumProvider.GetById(transactionManager, (entity.AlbumId ?? (int)0));		
				
				#if NETTIERS_DEBUG
				System.Diagnostics.Debug.WriteLine("- property 'AlbumIdSource' loaded. key " + entity.EntityTrackingKey);
				#endif 
				
				if (deep && entity.AlbumIdSource != null)
				{
					innerList.SkipChildren = true;
					DataRepository.AlbumProvider.DeepLoad(transactionManager, entity.AlbumIdSource, deep, deepLoadType, childTypes, innerList);
					innerList.SkipChildren = false;
				}
					
			}
			#endregion AlbumIdSource
			
			//used to hold DeepLoad method delegates and fire after all the local children have been loaded.
			Dictionary<string, KeyValuePair<Delegate, object>> deepHandles = new Dictionary<string, KeyValuePair<Delegate, object>>();
			
			//Fire all DeepLoad Items
			foreach(KeyValuePair<Delegate, object> pair in deepHandles.Values)
		    {
                pair.Key.DynamicInvoke((object[])pair.Value);
		    }
			deepHandles = null;
		}
		
		#endregion 
		
		#region DeepSave Methods

		/// <summary>
		/// Deep Save the entire object graph of the NguyenHoa.Domains.Multimedia object with criteria based of the child 
		/// Type property array and DeepSaveType.
		/// </summary>
		/// <param name="transactionManager">The transaction manager.</param>
		/// <param name="entity">NguyenHoa.Domains.Multimedia instance</param>
		/// <param name="deepSaveType">DeepSaveType Enumeration to Include/Exclude object property collections from Save.</param>
		/// <param name="childTypes">NguyenHoa.Domains.Multimedia Property Collection Type Array To Include or Exclude from Save</param>
		/// <param name="innerList">A Hashtable of child types for easy access.</param>
		public override bool DeepSave(TransactionManager transactionManager, NguyenHoa.Domains.Multimedia entity, DeepSaveType deepSaveType, System.Type[] childTypes, DeepSession innerList)
		{	
			if (entity == null)
				return false;
							
			#region Composite Parent Properties
			//Save Source Composite Properties, however, don't call deep save on them.  
			//So they only get saved a single level deep.
			
			#region AlbumIdSource
			if (CanDeepSave(entity, "Album|AlbumIdSource", deepSaveType, innerList) 
				&& entity.AlbumIdSource != null)
			{
				DataRepository.AlbumProvider.Save(transactionManager, entity.AlbumIdSource);
				entity.AlbumId = entity.AlbumIdSource.Id;
			}
			#endregion 
			#endregion Composite Parent Properties

			// Save Root Entity through Provider
			if (!entity.IsDeleted)
				this.Save(transactionManager, entity);
			
			//used to hold DeepSave method delegates and fire after all the local children have been saved.
			Dictionary<string, KeyValuePair<Delegate, object>> deepHandles = new Dictionary<string, KeyValuePair<Delegate, object>>();
			//Fire all DeepSave Items
			foreach(KeyValuePair<Delegate, object> pair in deepHandles.Values)
		    {
                pair.Key.DynamicInvoke((object[])pair.Value);
		    }
			
			// Save Root Entity through Provider, if not already saved in delete mode
			if (entity.IsDeleted)
				this.Save(transactionManager, entity);
				

			deepHandles = null;
						
			return true;
		}
		#endregion
	} // end class
	
	#region MultimediaChildEntityTypes
	
	///<summary>
	/// Enumeration used to expose the different child entity types 
	/// for child properties in <c>NguyenHoa.Domains.Multimedia</c>
	///</summary>
	public enum MultimediaChildEntityTypes
	{
		
		///<summary>
		/// Composite Property for <c>Album</c> at AlbumIdSource
		///</summary>
		[ChildEntityType(typeof(Album))]
		Album,
		}
	
	#endregion MultimediaChildEntityTypes
	
	#region MultimediaFilterBuilder
	
	/// <summary>
	/// A strongly-typed instance of the <see cref="SqlFilterBuilder&lt;MultimediaColumn&gt;"/> class
	/// that is used exclusively with a <see cref="Multimedia"/> object.
	/// </summary>
	[CLSCompliant(true)]
	public class MultimediaFilterBuilder : SqlFilterBuilder<MultimediaColumn>
	{
		#region Constructors

		/// <summary>
		/// Initializes a new instance of the MultimediaFilterBuilder class.
		/// </summary>
		public MultimediaFilterBuilder() : base() { }

		/// <summary>
		/// Initializes a new instance of the MultimediaFilterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		public MultimediaFilterBuilder(bool ignoreCase) : base(ignoreCase) { }

		/// <summary>
		/// Initializes a new instance of the MultimediaFilterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		/// <param name="useAnd">Specifies whether to combine statements using AND or OR.</param>
		public MultimediaFilterBuilder(bool ignoreCase, bool useAnd) : base(ignoreCase, useAnd) { }

		#endregion Constructors
	}

	#endregion MultimediaFilterBuilder
	
	#region MultimediaParameterBuilder
	
	/// <summary>
	/// A strongly-typed instance of the <see cref="ParameterizedSqlFilterBuilder&lt;MultimediaColumn&gt;"/> class
	/// that is used exclusively with a <see cref="Multimedia"/> object.
	/// </summary>
	[CLSCompliant(true)]
	public class MultimediaParameterBuilder : ParameterizedSqlFilterBuilder<MultimediaColumn>
	{
		#region Constructors

		/// <summary>
		/// Initializes a new instance of the MultimediaParameterBuilder class.
		/// </summary>
		public MultimediaParameterBuilder() : base() { }

		/// <summary>
		/// Initializes a new instance of the MultimediaParameterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		public MultimediaParameterBuilder(bool ignoreCase) : base(ignoreCase) { }

		/// <summary>
		/// Initializes a new instance of the MultimediaParameterBuilder class.
		/// </summary>
		/// <param name="ignoreCase">Specifies whether to create case-insensitive statements.</param>
		/// <param name="useAnd">Specifies whether to combine statements using AND or OR.</param>
		public MultimediaParameterBuilder(bool ignoreCase, bool useAnd) : base(ignoreCase, useAnd) { }

		#endregion Constructors
	}

	#endregion MultimediaParameterBuilder
	
	#region MultimediaSortBuilder
    
    /// <summary>
    /// A strongly-typed instance of the <see cref="SqlSortBuilder&lt;MultimediaColumn&gt;"/> class
	/// that is used exclusively with a <see cref="Multimedia"/> object.
    /// </summary>
    [CLSCompliant(true)]
    public class MultimediaSortBuilder : SqlSortBuilder<MultimediaColumn>
    {
		#region Constructors

		/// <summary>
		/// Initializes a new instance of the MultimediaSqlSortBuilder class.
		/// </summary>
		public MultimediaSortBuilder() : base() { }

		#endregion Constructors

    }    
    #endregion MultimediaSortBuilder
	
} // end namespace
